Ser. No. 10/761,767 

Amendment in Reply to OA of 03/03/2009 
Amendments to the Claims : 

This listing of claims will replace all prior versions, and listings, of claims in the 
application: 

Listing of Claims : 

1 . (Previously presented) A method of processing a series of data packets for transmission 
over a data network in a series of frames, each data packet in the series of data packets having a 
respective time in a time sequence, each frame being capable of transmitting a certain amount of 
data, the method comprising: 

successively joining data packets from the time sequence into the frames and delaying 
transmission of some of the data packets so that at least some of the frames each contain multiple 
data packets, and transmitting each data packet in at least one of the frames no later than a 
certain time interval after the respective time of said each data packet in the time sequence, 
which includes 

(a) transmitting each frame in a first set of the frames upon filling said each frame in the 
first set of frames with data from one or more of the data packets so that said each frame in the 
first set of frames cannot contain an additional data packet; and 

(b) upon delaying packet transmission for the certain time interval, transmitting each 
frame in a second set of the frames which are not filled with at least some of the data packets so 
that said each frame in the second set of the frames cannot contain an additional data packet in 
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order to ensure that said each data packet is transmitted in at least one of the frames no later than 
the certain time interval after the respective time of said each data packet in the time sequence. 

2. (Original) The method as claimed in claim 1, wherein a main routine for processing said 
each data packet initiates the transmitting of each frame in the first set of the frames upon filling 
said each frame in the first set of frames with data from one or more of the data packets so that 
said each frame in the first set of frames cannot contain an additional data packet; and 

wherein a timer interrupt routine initiates the transmitting of each frame in the second set 
of the frames which are not filled with at least some of the data packets so that said each frame in 
the second set of the frames cannot contain an additional data packet in order to ensure that said 
each data packet is transmitted in at least one of the frames no later than the certain time interval 
after the respective time of said each data packet in the time sequence. 

3. (Original) The method as claimed in claim 1, wherein the data packets include read I/O 
request data packets and write I/O request data packets, and the method includes separately 
joining the read I/O request data packets together for transmission, and separately joining the 
write I/O request data packets together for transmission, so that the I/O request data packets have 
an ordering in the frames that is different from the ordering of the I/O request data packets in the 
time sequence. 

4. (Original) The method as claimed in claim 3, wherein some of the read I/O request data 
packets are moved in front of some of the write I/O request data packets in some of the frames. 
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5. (Original) The method of claim 1, wherein the data packets are I/O request data packets, 
and the method includes on-line transaction processing applications in a host processor 
producing the data packets, and a TCP/IP interface in the host processor transmitting the frames 
over an IP network to network attached storage containing a database accessed by the on-line 
transaction processing applications. 

6. (Original) The method of claim 1, wherein the data packets are I/O replies from network 
attached storage, and the frames are transmitted to a host processor accessing the network 
attached storage. 

7. (Original) The method of claim 1, wherein the data packets are stored in a range of 
addresses of memory, a certain number of frames are preallocated in another region of memory, 
and the data packets are joined by transfer of the data packets from the range of addresses in 
memory to the preallocated frames in memory. 

8. (Original) The method of claim 7, wherein the certain number of preallocated frames are 
periodically updated. 

9. (Original) The method of claim 7, which includes application threads loading the data 
packets into the memory at the range of addresses in memory. 
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10. (Original) The method of claim 7, which includes TCP/IP threads accessing the pool of 
preallocated frames for transmission of the preallocated frames including the data packets over 
an IP network. 

11. (Original) The method as claimed in claim 1, which includes transmitting the frames 
over a data network, measuring loading on the data network, and dynamically adjusting the 
duration of the certain time interval based on the measured loading of the data network, the 
duration of the certain time interval being increased for increased loading on the data network. 

Claim 12. (Canceled). 

13. (Currently amended) The m e thod as claim e d in claim 12, In a host processor 
programmed for executing on-line transaction processing applications and having a network 
block storage interface for accessing network attached storage coupled to the host processor via a 
data network, a method comprising the host processor joining I/O request data packets from 
different ones of the on-line transaction processing applications in the same network 
transmission frames to more completely fill the network transmission frames, which includes the 
host processor delaying transmission of some of the I/O request data packets by a certain time 
interval so that at least some of the network transmission frames each contain multiple I/O 
request data packets, and transmitting each I/O request data packet in a frame no later than the 
certain time interval after said each I/O request data packet is produced by one of the on-line 
transaction processing applications,, 
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wherein the network transmission frames include a first set of frames in which each 
frame in the first set of frames is transmitted upon filling said each frame in the first set of 
frames with data from one or more of the I/O request data packets so that said each frame in the 
first set of frames cannot contain an additional I/O request data packet; and 

the network transmission frames include a second set of frames in which each frame in 
the second set of frames is transmitted upon delaying packet transmission for the certain time 
interval and said each frame in the second set of frames is not filled with data from one or more 
of the I/O request data packets so that said each frame in the second set of frames cannot contain 
an additional I/O request data packet . 

14. (Original) The method as claimed in claim 13, which includes the host processor 
dynamically adjusting the certain time interval in response to loading on the data network, the 
certain time interval being increased for increased loading on the data network. 

15. (Currently amended) The method as claimed in claim [[12]] 13, which includes the host 
processor executing a periodic timer interrupt routine to insure that each I/O request data packet 
is transmitted in a frame no later than a certain time interval after said each I/O request data 
packet is produced by one of the on-line transaction processing applications. 

16. (Currently amended) The method as claimed in claim [[12]] 13, wherein the I/O request 
data packets include read I/O request data packets and write I/O request data packets, and the 
method includes separately joining the read I/O request data packets together for transmission to 
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the network block storage, and separately joining the write I/O request data packets together for 
transmission to the network block storage. 

17. (Original) The method as claimed in claim 16, which includes moving some of the read 
I/O request data packets in front of some of the write I/O request data packets in some of the 
frames. 

18. (Currently amended) The method as claimed in claim [[12]] 13, which includes turning 
on and off the joining of the I/O request data packets. 

19. (Currently amended) The method as claimed in claim [[12]] 13, wherein the joining of 
the I/O request data packets is turned off during a bulk transfer of database data. 

20. (Currently amended) The method as claimed in claim [[12]] 13, which includes the host 
processor executing an I/O request bunching routine that intercepts I/O request data packets sent 
from the on-line transaction processing applications to a network block storage interface. 

21. (Currently amended) The method of claim [[12]] 13, which includes storing the I/O 
request data packets in a range of addresses of memory, preallocating a certain number of frames 
in another region of memory, and joining the data packets during transfer of the data packets 
from the range of addresses in memory to the preallocated frames in memory. 
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22. (Original) The method of claim 21, which includes periodically updating the certain 
number of preallocated frames. 

23. (Currently amended) The method as claimed in claim [[12]] 13, which includes the 
network attached storage bunching I/O replies into frames for transmission from the network 
attached storage over the data network to the host processor. 

24. (Canceled). 

25. (Currently amended) Th e m e thod as claim e d in claim 2 4 , A method of solving a 
performance problem in a host processor programmed for executing on-line transaction 
processing applications and having a network block storage interface for accessing network 
attached storage coupled to the host processor via a data network, the performance problem 
being caused by network transmission frames being only partially filled with I/O request data 
packets from the on-line transaction processing applications, the performance problem being 
solved by re-programming the host processor to join the I/O request data packets from different 
ones of the on-line transaction processing applications in the same network transmission frames 
to more completely fill the network transmission frames, which includes re-programming the 
host processor to delay transmission of some of the I/O request data packets by a certain time 
interval so that at least some of the network transmission frames each contain multiple I/O 
request data packets, and to transmit each I/O request data packet in a frame no later than the 
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certain time interval after said each I/O request data packet is produced by one of the on-line 
transaction processing applications^ 

wherein the network transmission frames include a first set of frames in which each 
frame in the first set of frames is transmitted upon filling said each frame in the first set of 
frames with data from one or more of the I/O request data packets so that said each frame in the 
first set of frames cannot contain an additional I/O request data packet; and 

the network transmission frames include a second set of frames in which each frame in 
the second set of frames is transmitted upon delaying packet transmission for the certain time 
interval and said each frame in the second set of frames is not filled with data from one or more 
of the I/O request data packets so that said each frame in the second set of frames cannot contain 
an additional I/O request data packet . 

26. (Original) The method as claimed in claim 25, which includes re-programming the host 
processor for dynamic adjustment of the certain time interval in response to loading on the data 
network, the certain time interval being increased for increased loading on the data network. 

27. (Currently amended) The method as claimed in claim [[24]] 25, wherein the re- 
programming of the host processor includes adding a periodic timer interrupt routine to insure 
that each I/O request data packet is transmitted in a frame no later than a certain time interval 
after said each I/O request data packet is produced by one of the on-line transaction processing 
applications. 
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28. (Currently amended) The method as claimed in claim [[24]] 25, wherein the I/O request 
data packets include read I/O request data packets and write I/O request data packets, and the 
host processor is re-programmed for separately joining the read I/O request data packets together 
for transmission to the network block storage, and separately joining the write I/O request data 
packets together for transmission to the network block storage. 

29. (Original) The method as claimed in claim 28, wherein the host processor is 
reprogrammed to move some of the read I/O request data packets in front of some of the write 
I/O request data packets in some of the frames. 

30. (Currently amended) The method as claimed in claim [[24]] 25, which includes re- 
programming the host processor for turning on and off the joining of the I/O request data 
packets. 

31. (Currently amended) The method as claimed in claim [[24]] 25, wherein the host 
processor is re-programmed by adding an I/O request bunching module that intercepts I/O 
request data packets sent from the on-line transaction processing applications to a network block 
storage interface. 

32. (Currently amended) The method as claimed in claim [[24]] 25, wherein the host 
processor is re-programmed by modifying programming in the network block storage interface 
that packs the frames with the I/O request data packets. 
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33. (Currently amended) The method as claimed in claim [[24]] 25, which includes re- 
programming the network attached storage to bunch I/O replies into frames for transmission 
from the network attached storage over the data network to the host processor. 

34. (Canceled). 

35. (Currently amended) Th e host processor as claim e d in claim 3 4 , A host processor 
programmed for executing on-line transaction processing applications and having a network 
block storage interface for accessing network attached storage coupled to the host processor via a 
data network, the host processor being programmed for joining the I/O request data packets from 
different ones of the on-line transaction processing applications into the same network 
transmission frames to more completely fill the network transmission frames, wherein the host 
processor is programmed for_delaying transmission of some of the I/O request data packets by a 
certain time interval so that at least some of the network transmission frames each contain 
multiple I/O request data packets, and transmitting each I/O request data packet in a frame no 
later than the certain time interval after said each I/O request data packet is produced by one of 
the on-line transaction processing applications , and 

wherein the host processor is programmed to transmit each network transmission frame 
upon the earlier of either filling said each network transmission frame with data from one or 
more of the I/O request data packets so that said each network transmission frame cannot contain 
an additional I/O request data packet, or delaying packet transmission for the certain time 
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interval so that the network transmission frames include a first set of frames in which each 
frame in the first set of frames is transmitted upon filling said each frame in the first set of 
frames with data from one or more of the I/O request data packets so that said each frame in the 
first set of frames cannot contain an additional I/O request data packet and a second set of 
frames in which each frame in the second set of frames is transmitted upon delaying packet 
transmission for the certain time interval, and said each frame in the second set of frames is not 
filled with data from one or more of the I/O request data packets so that said each frame in the 
second set of frames cannot contain an additional I/O request data packet . 

36. (Original) The host processor as claimed in claim 35, wherein the host processor is 
programmed for dynamically adjusting the certain time interval in response to loading on the 
data network, the certain time interval being increased for increased loading on the data network. 

37. (Currently amended) The host processor as claimed in claim [[34]] 35, wherein the host 
processor is programmed with a periodic timer interrupt routine to insure that each I/O request 
data packet is transmitted in a frame no later than a certain time interval after said each I/O 
request data packet is produced by one of the on-line transaction processing applications. 

38. (Currently amended) The host processor as claimed in claim [[34]] 35, wherein the I/O 
request data packets include read I/O request data packets and write I/O request data packets, and 
the host processor is programmed for separately joining the read I/O request data packets 
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together for transmission to the network block storage, and for separately joining the write I/O 
request data packets together for transmission to the network block storage. 

39. (Original) The host processor as claimed in claim 38, which is programmed for moving 
some of the read I/O request data packets in front of some of the write I/O request data packets in 
some of the frames. 

40. (Currently amended) The host processor as claimed in claim [[34]] 35, wherein the host 
processor is programmed for turning on and off the joining of the I/O request data packets. 

41. (Currently amended) The host processor as claimed in claim [[34]] 35, wherein the host 
processor is programmed with an I/O request bunching routine that intercepts I/O request data 
packets sent from the on-line transaction processing applications to the network block storage 
interface. 

42. (Currently amended) The host processor as claimed in claim [[34]] 35, wherein the host 
processor is programmed for storing the I/O request data packets in a range of addresses of 
memory, preallocating a certain number of frames in another region of memory, and joining the 
data packets during transfer of the data packets from the range of addresses in memory to the 
preallocated frames in memory. 
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43. (Original) The host processor as claimed in claim 42, which is programmed for 
periodically updating the certain number of preallocated frames. 
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